#### **CS221:** Digital Design

http://jatinga.iitg.ernet.in/~asahu/cs221

# **FSM State Encoding**

A. Sahu

Dept of Comp. Sc. & Engg.

Indian Institute of Technology Guwahati

# **Encoding**

- Random Encoding
- Sequential Encoding
- Gray Encoding
- One Hot Encoding
- Output Oriented Encoding
- Heuristics for Encoding

## **Quiz 2B: Q1**

- Counter sequences 1, 4, 7, 2 ....
- Naïve design 3 FF, 8 states, JK –FF, 8 functions input but no output logic
  - 6 three input functions, 8 states out of 4 are used
- Intelligent Design
  - 2 States, 00, 01, 10, 11: 4 (two variable) inputs for JK
  - 3 output for each it (Z2=A xor B, Z1=A, Z0=B')
  - Total of 7 two input functions

| PS (A,B) | NS | OUT   |
|----------|----|-------|
| 00       | 01 | 0 0 1 |
| 01       | 10 | 1 0 0 |
| 10       | 11 | 1 1 1 |
| 11       | 00 | 0 1 0 |

# **State Encoding/Assignment**

#### State assignment

- Since we don't care about the actual flip-flop values for each state we can assign each state to any binary number we like as long as each state is assigned a unique binary number
- Suppose a FSM have 5 states
- If we use 3 bits to encode the 5 states, we have

$$\binom{8}{5} = \frac{8!}{5!(8-5)!}$$

possible encodings

#### State assignment

| state | Encoding 1 (binary) | Encoding<br>2<br>(Gray) | Encoding<br>3 |
|-------|---------------------|-------------------------|---------------|
| a     | 000                 | 000                     | 000           |
| b     | 001                 | 001                     | 100           |
| C     | 010                 | 011                     | 010           |
| d     | 011                 | 010                     | 101           |
| e     | 100                 | 110                     | 011           |

### **State Encoding**

- Binary and Gray encoding use the minimum number of bits for state register
- Gray and Johnson code: Two adjacent codes differ by only one bit
  - Reduce simultaneous switching
  - Reduce crosstalk, Reduce glitch

## **One-hot encoding**

- One flip-flop per state encoding
- Leads to greater number of flip-flops than binary encoding but possibly to simpler logic

#### **State Assignment Problem**

- Some state assignments are better than others.
- The state assignment influences the complexity of the state machine.
  - The combinational logic required in the state machine design is dependent on the state assignment.
- Types of state assignment
  - Binary encoding:  $2^N$  states  $\rightarrow$  N Flip-Flops
  - Gray-code encoding:  $2^N$  states  $\rightarrow$  N Flip-Flops
  - One-hot encoding: N states → N Flip-Flops

#### Example

Design a FSM that detects a sequence of two or more consecutive ones on an input bit stream.

The FSM should output a 1 when the sequence is detected, and a 0 otherwise.

Input: 011101011011101...

Output: 001100001001100...



| Present<br>State | Next           | Output         |   |
|------------------|----------------|----------------|---|
|                  | w = 0          |                |   |
| S <sub>0</sub>   | S <sub>0</sub> | S <sub>1</sub> | 0 |
| S <sub>1</sub>   | S <sub>0</sub> | S <sub>2</sub> | 0 |
| S <sub>2</sub>   | S <sub>0</sub> | S <sub>2</sub> | 1 |

State Table

#### State Assigned Table

| Pre            | sent S | tate        | Next State       |                               |         |                           |         | Output  |   |
|----------------|--------|-------------|------------------|-------------------------------|---------|---------------------------|---------|---------|---|
|                |        |             | $\mathbf{w} = 0$ |                               |         | w = 1                     |         |         |   |
|                | Q      | $Q_{\rm B}$ |                  | $\mathbf{Q}_{\mathbf{A}}^{+}$ | $Q_B^+$ |                           | $Q_A^+$ | $Q_B^+$ | Z |
| $S_0$          | 0      | 0           | $S_0$            | 0                             | 0       | $S_1$                     | 0       | 1       | 0 |
| $S_1$          | 0      | 1           | $S_0$            | 0                             | 0       | $\overline{\mathbf{S_2}}$ | 1       | 0       | 0 |
| S <sub>2</sub> | 1      | 0           | $S_0$            | 0                             | 0       | $S_2$                     | 1       | 0       | 1 |
|                | 1      | 1/          |                  | d                             | d       |                           | d       | d       | d |

Using **Binary** Encoding for the State Assignment

$$D_{B}=wQ'_{A}Q_{B}'$$

$$D_{A}=w(Q_{A}+Q_{B})$$

$$Z=Q_{A}$$

#### **State Assigned Table**

| Pres  | sent S | State       | Next State       |         |                  |       |         | Output  |   |
|-------|--------|-------------|------------------|---------|------------------|-------|---------|---------|---|
|       |        |             | $\mathbf{w} = 0$ |         | $\mathbf{w} = 1$ |       |         |         |   |
|       | Q      | $Q_{\rm B}$ |                  | $Q_A^+$ | $Q_{B}^{+}$      |       | $Q_A^+$ | $Q_B^+$ | Z |
| $S_0$ | 0      | 0           | $S_0$            | 0       | 0                | $S_1$ | 0       | 1       | 0 |
| $S_1$ | 0      | 1           | $S_0$            | 0       | 0                | $S_2$ | 1       | 1       | 0 |
| $S_2$ | 1      | 1 /         | $S_0$            | 0       | 0                | $S_2$ | 1       | 1       | 1 |
|       | 1      | 0           | V                | d       | d                |       | d       | d       | d |

Using <u>Gray-code</u> Encoding for the State Assignment

 $D_A = w.Q_B$   $D_B = W$   $Z = Q_A$ 

State Assigned Table

| Pr    | resent State   |         |                  |       | Next State |         |         |       |         |                 |         |
|-------|----------------|---------|------------------|-------|------------|---------|---------|-------|---------|-----------------|---------|
|       |                |         | $\mathbf{w} = 0$ |       |            | w = 1   |         |       |         |                 |         |
|       | Q <sub>A</sub> | $Q_{B}$ | $Q_{C}$          |       | $Q_A^+$    | $Q_B^+$ | $Q_{C}$ |       | $Q_A^+$ | $Q_{\rm B}^{+}$ | $Q_{C}$ |
| $S_0$ | 0              | 0       | 1                | $S_0$ | 0          | 0       | 1       | $S_1$ | 0       | 1               | 0       |
| $S_1$ | 0              | 1       | 0                | $S_0$ | 0          | 0       | 1       | $S_2$ | 1       | 0               | 0       |
| $S_2$ | 1              | Q       | 0/               | $S_0$ | 0          | 0       | 1       | $S_2$ | 1       | 0               | 0       |

Using One-hot Encoding for the State Assignment

For each state only one flip-flop is set to 1.

The remaining combination of state variables are not used.

 $D_A = w.Q_c'$   $D_B = w.Q_c$  $D_C = w'$ 

# **State Encoding**

| # | Binary | Gray | Johnson | One-hot  |
|---|--------|------|---------|----------|
|   |        |      |         |          |
| 0 | 000    | 000  | 0000    | 0000001  |
| 1 | 001    | 001  | 0001    | 0000010  |
| 2 | 010    | 011  | 0011    | 00000100 |
| 3 | 011    | 010  | 0111    | 00001000 |
| 4 | 100    | 110  | 1111    | 00010000 |
| 5 | 101    | 111  | 1110    | 00100000 |
| 6 | 110    | 101  | 1100    | 01000000 |
| 7 | 111    | 100  | 1000    | 10000000 |

#### **State Encoding**

- The cost & delay of FSM implementation depends on encoding of symbolic states.
  - e.g., 4 states can be encoded in 4! = 24 different ways
- There are more than n! different encodings for n states.
  - Exploration of all encodings is impossible, therefore heuristics are used
- Heuristics Used
  - One-hot encoding, Minimum-bit change,
     Prioritized adjacency

# **One-hot Encoding**

- Uses redundant encoding in which one flip-flop is assigned to each state.
- Each state is distinguishable by its own flip-flop having a value of 1 while all others have a value of 0.

A: 001

B: 010

C: 100



#### **Minimum-bit Change**

- Assigns codes to states so that
  - —The total number of bit changes for all state transitions is minimized.
- In other words, if every arc in the state diagram has a weight
  - That is equal to the **number of bits** by which the source and destination encoding **differ**
  - This strategy would select the one that minimizes the sum of all these weights.

# **Minimum-bit Change**

Encoding with 6 bit changes



Straight-forward sequential Encoding

Encoding with 4 bit changes



Minimum Bit Change Encoding

#### The Idea of Adjacency

- Inputs are A and B
- State variables are Y1 and Y2
- An output is F(A, B, Y1, Y2) or F(Y1,Y2)
- A next state function is G(A, B, Y1, Y2)

Karnaugh map of output function or next state function

Y1

Y1

Y1

Y1

Y2

- Larger clusters produce smaller logic function.
- Clustered minterms differ in one variable.

#### Size of an Implementation

- Number of product terms determines number of gates.
- Number of literals in a product term determines number of gate inputs, which is proportional to number of transistors.
- Hardware area proportional to total number of literals
- Examples of four minterm functions:
  - F1 = ABCD +A'B'C'D' +A'B'CD +A'B' CD has 16 literals
  - F2 = ABC +A'C'D has 6 literals

# Rule 1 (Priority #1), Common Dest

States that have the same next state for some fixed input should be assigned logically adjacent codes.



# Rule 1 (Priority #1), Common Dest

States that have the same next state for some fixed input should be assigned logically adjacent codes.



Rule #1: (S<sub>1</sub>, S<sub>2</sub>)

The input value of 0 will move both states into the same state S<sub>3</sub>

25

#### Rule 2 (Priority #2), A Common Source

States that are the next states of the same state under logically adjacent inputs, should be assigned logically adjacent codes.



#### Rule 2 (Priority #2), A Common Source

States that are the next states of the same state under logically adjacent inputs, should be assigned logically adjacent codes.



Rule #2: (S<sub>1</sub>, S<sub>2</sub>)

They are both next states of the state S<sub>0</sub>

#### Rule 3 (Priority #3), A Common Output

States that have the same output value for the same input value, should be assigned logically adjacent codes.



#### Rule 3 (Priority #3), A Common Output

States that have the same output value for the same input value, should be assigned logically adjacent codes.



Rule #3:  $(S_0, S_1)$ , and  $(S_2, S_3)$ , states  $S_0$  and  $S_1$  have the same output value 0 for the same input value 0

29

# **Applying Rules 1,2 and 3**



## **Example of State Assignment**







Verify that BC and AD are not adjacent.

#### **State Assignment #1**

A = 00, B = 01, C = 10, D = 11

| Present state | Next state, output Y1*Y2*, Z |      |  |  |
|---------------|------------------------------|------|--|--|
| Y1, Y2        | Input, X<br>0 1              |      |  |  |
| A = 00        | 10/0                         | 11/0 |  |  |
| B = 01        | 10/0                         | 00/0 |  |  |
| C = 10        | 01/0                         | 11/0 |  |  |
| D = 11        | 00/1                         | 01/1 |  |  |

| Input | Present state |    | Output |     | ext<br>ate |
|-------|---------------|----|--------|-----|------------|
| X     | Y1            | Y2 | Z      | Y1* | Y2*        |
| 0     | 0             | 0  | 0      | 1   | 0          |
| 0     | 0             | 1  | 0      | 1   | 0          |
| 0     | 1             | 0  | 0      | 0   | 1          |
| 0     | 1             | 1  | 1      | 0   | 0          |
| 1     | 0             | 0  | 0      | 1   | 1          |
| 1     | 0             | 1  | 0      | 0   | 0          |
| 1     | 1             | 0  | 0      | 1   | 1          |
| 1     | 1             | 1  | 1      | 1   | 0          |

# Logic Minimization for Optimum State <u>Assignment</u>



#### Using an Arbitrary State Assignment: A = 00, B = 01, C = 11, D = 10

| Present state | Next state, output Y1*Y2*, Z |      |  |  |
|---------------|------------------------------|------|--|--|
| Y1, Y2        | Input, X<br>0 1              |      |  |  |
| A = 00        | 11/0                         | 10/0 |  |  |
| B = 01        | 11/0                         | 00/0 |  |  |
| C = 11        | 01/0                         | 10/0 |  |  |
| D = 10        | 00/1                         | 01/1 |  |  |

| Input | Present state |    | Output |     | ext<br>ate |
|-------|---------------|----|--------|-----|------------|
| X     | Y1            | Y2 | Z      | Y1* | Y2*        |
| 0     | 0             | 0  | 0      | 1   | 1          |
| 0     | 0             | 1  | 0      | 1   | 1          |
| 0     | 1             | 0  | 1      | 0   | 0          |
| 0     | 1             | 1  | 0      | 0   | 1          |
| 1     | 0             | 0  | 0      | 1   | 0          |
| 1     | 0             | 1  | 0      | 0   | 0          |
| 1     | 1             | 0  | 1      | 0   | 1          |
| 1     | 1             | 1  | 0      | 1   | 0          |

# Logic Minimization for Arbitrary State Assignment

